Multidimensional Array এবং Dynamic Array

Java Technologies - জাভা দিয়ে ডাটা স্ট্রাকচার এবং অ্যালগরিদম (DSA using Java) - অ্যারে (Array)
410

ডাটা স্ট্রাকচার এবং অ্যালগরিদম এর মধ্যে, Multidimensional Array এবং Dynamic Array দুটি গুরুত্বপূর্ণ ধারণা যা জাভাতে ডেটা সংরক্ষণ এবং পরিচালনা করার জন্য ব্যবহৃত হয়। এই দুটি কনসেপ্টের মধ্যে পার্থক্য এবং কিভাবে জাভাতে এগুলি ব্যবহৃত হয়, তা জানবো।


১. Multidimensional Array

Multidimensional Array হল এমন একটি অ্যারে যা একাধিক ডাইমেনশন বা মাত্রা নিয়ে গঠিত। এটি সাধারণত Row x Column এর আকারে হয় এবং বিভিন্ন ধরনের matrix বা grid ডেটা সংরক্ষণ করতে ব্যবহৃত হয়। জাভাতে, একটি মাল্টিডাইমেনশনাল অ্যারে একটি অ্যারের মধ্যে আরেকটি অ্যারে থাকতে পারে।

উদাহরণ: 2D Array (Two-Dimensional Array)

একটি সাধারণ 2D অ্যারে যেখানে রো (row) এবং কলাম (column) থাকে, সেগুলোকে ধারণ করা হয়।

public class MultiDimensionalArrayExample {
    public static void main(String[] args) {
        // 2D Array Declaration and Initialization
        int[][] matrix = {
            {1, 2, 3},
            {4, 5, 6},
            {7, 8, 9}
        };

        // Accessing elements in a 2D Array
        System.out.println("Element at [0][0]: " + matrix[0][0]);
        System.out.println("Element at [1][1]: " + matrix[1][1]);
        System.out.println("Element at [2][2]: " + matrix[2][2]);

        // Iterating over 2D Array
        System.out.println("Iterating through the 2D array:");
        for (int i = 0; i < matrix.length; i++) {
            for (int j = 0; j < matrix[i].length; j++) {
                System.out.print(matrix[i][j] + " ");
            }
            System.out.println();
        }
    }
}

ব্যাখ্যা:

  • 2D Array Declaration: int[][] matrix দ্বারা 2D অ্যারে ডিক্লেয়ার করা হয়েছে। এটি একটি অ্যারে যেটি আবার অন্য অ্যারে ধারণ করে।
  • Accessing elements: অ্যারের নির্দিষ্ট অবস্থান অ্যাক্সেস করা হয় যেমন matrix[0][0]
  • Iterating: একটি লুপ ব্যবহার করে অ্যারের সমস্ত উপাদান ভ্রমণ করা হয়।

আউটপুট:

Element at [0][0]: 1
Element at [1][1]: 5
Element at [2][2]: 9
Iterating through the 2D array:
1 2 3 
4 5 6 
7 8 9 

অন্যান্য Multidimensional Array:

  • 3D Array: একটি 3D অ্যারে হল একাধিক 2D অ্যারের集合।

    int[][][] cube = new int[3][3][3]; // 3x3x3 3D Array
    
  • Jagged Arrays: এটি একটি বিশেষ ধরনের মাল্টিডাইমেনশনাল অ্যারে যেখানে প্রতিটি রো (row) আলাদা সাইজের হতে পারে।

    int[][] jaggedArray = {
        {1, 2, 3},
        {4, 5},
        {6, 7, 8, 9}
    };
    

২. Dynamic Array

Dynamic Array এমন একটি অ্যারে যা আকারে পরিবর্তনশীল। এটি সাধারণত একটি Resizable Array বা ArrayList হিসাবে পরিচিত। জাভাতে ArrayList ডাইনামিক অ্যারে হিসেবে ব্যবহৃত হয়, যা স্বয়ংক্রিয়ভাবে তার আকার বাড়ায় বা কমায় যখন নতুন উপাদান যুক্ত বা মুছে ফেলা হয়।

উদাহরণ: ArrayList (Dynamic Array)

import java.util.ArrayList;

public class DynamicArrayExample {
    public static void main(String[] args) {
        // ArrayList Declaration and Initialization
        ArrayList<Integer> numbers = new ArrayList<>();

        // Adding elements to ArrayList
        numbers.add(10);
        numbers.add(20);
        numbers.add(30);
        numbers.add(40);

        // Accessing elements from ArrayList
        System.out.println("Element at index 0: " + numbers.get(0));
        System.out.println("Element at index 2: " + numbers.get(2));

        // Iterating over ArrayList
        System.out.println("Iterating through ArrayList:");
        for (int number : numbers) {
            System.out.print(number + " ");
        }

        // Removing an element
        numbers.remove(1); // Removes element at index 1

        // Checking size
        System.out.println("\nSize of ArrayList: " + numbers.size());

        // Iterating after removal
        System.out.println("Iterating after removal:");
        for (int number : numbers) {
            System.out.print(number + " ");
        }
    }
}

ব্যাখ্যা:

  • ArrayList Declaration: ArrayList<Integer> numbers = new ArrayList<>(); দ্বারা ডাইনামিক অ্যারে ডিক্লেয়ার করা হয়েছে।
  • Adding elements: add() মেথড দিয়ে উপাদান যুক্ত করা হয়েছে।
  • Accessing elements: get() মেথড দিয়ে উপাদান অ্যাক্সেস করা হয়েছে।
  • Removing elements: remove() মেথড দিয়ে উপাদান মুছে ফেলা হয়েছে।
  • Size: size() মেথড ব্যবহার করে ArrayList এর সাইজ পাওয়া যায়।

আউটপুট:

Element at index 0: 10
Element at index 2: 30
Iterating through ArrayList:
10 20 30 40 
Size of ArrayList: 4
Iterating after removal:
10 30 40 

অন্যান্য Dynamic Array এর বৈশিষ্ট্য:

  1. Automatic Resizing: ArrayList যখন পূর্ণ হয়ে যায়, তখন এটি স্বয়ংক্রিয়ভাবে তার আকার দ্বিগুণ করে।
  2. Memory Efficiency: ArrayList এর সাইজ বৃদ্ধি করা বা কমানো খুব সহজ এবং মেমরি ব্যবস্থাপনার জন্য আরও উপযুক্ত।
  3. Performance Considerations: ArrayList এর কিছু সীমাবদ্ধতা যেমন, ইনডেক্সিংয়ে O(1) সময় হলেও, মুছে ফেলা এবং ইনসার্ট অপারেশনগুলি O(n) সময় নিতে পারে যদি উপাদান গুলোকে সরাতে হয়।

৩. Multidimensional Array এবং Dynamic Array এর মধ্যে পার্থক্য

বৈশিষ্ট্যMultidimensional ArrayDynamic Array
আকৃতিস্থির, নির্দিষ্ট আকারের (এটি সংশোধন করা কঠিন)আকারে পরিবর্তনশীল (স্বয়ংক্রিয়ভাবে আকার পরিবর্তন হয়)
ইনডেক্সিংএকাধিক মাত্রা, সাধারণত রো এবং কলামে ইনডেক্স করা হয়একমাত্র ইনডেক্সিং, শুধু একটি মাত্রা
স্টোরেজআগের থেকেই প্রিসাইজড সাইজে স্টোরেজপ্রয়োজন অনুযায়ী মেমরি বৃদ্ধি করে
অপারেশনঐতিহ্যবাহী অ্যারে অপারেশন যেমন অ্যাক্সেস, অ্যাসাইনমেন্ট সহজArrayList এর মতো অপারেশন যেমন উপাদান যুক্ত করা, মুছে ফেলা সহজ
প্রয়োগ ক্ষেত্রম্যাট্রিক্স, টেবিল, বা গ্রিড ডেটা সঞ্চয়পরিবর্তনশীল ডেটার জন্য, যেমন লিস্ট, স্ট্যাক, কিউ

৪. কোথায় ব্যবহার করবেন?

  • Multidimensional Array: যখন আপনার একটি ফিক্সড আকারের গ্রিড বা ম্যাট্রিক্স দরকার হয় (যেমন, ইমেজ প্রসেসিং, গেমস, মেশিন লার্নিং মডেলিং)
  • Dynamic Array (ArrayList): যখন ডেটা পরিবর্তনশীল হয় এবং ডেটার সাইজ বার বার পরিবর্তিত হয় (যেমন, লিস্টের মধ্যে উপাদান যোগ বা মুছে ফেলা)

সারাংশ

Multidimensional Array এবং Dynamic Array জাভাতে দুটি গুরুত্বপূর্ণ ডেটা স্ট্রাকচার যা ডেটা সংরক্ষণের জন্য ব্যবহৃত হয়। Multidimensional Array একাধিক মাত্রায় ডেটা সংরক্ষণের জন্য ব্যবহৃত হয়, যেমন 2D বা 3D অ্যারে, যেখানে ডেটা একটি নির্দিষ্ট আকারে থাকে। অপরদিকে, Dynamic Array (ArrayList) আকারে পরিবর্তনশীল, এবং এটি জাভার একটি প্রিলোডেড ক্লাস যা দ্রুত ডেটা ইনসার্ট, ডিলিট এবং রিটার্ন করার জন্য উপযুক্ত।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...